Research
Security News
Quasar RAT Disguised as an npm Package for Detecting Vulnerabilities in Ethereum Smart Contracts
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
assign-deep
Advanced tools
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
Please consider following this project's author, Jon Schlinkert, and consider starring the project to show your :heart: and support.
Install with npm:
$ npm install --save assign-deep
Please update to version 1.0.1 or later, a critical bug was fixed in that version.
null
or undefined
source values.[[Get]]
is used on source objects and [[Set]]
is used on the target, so it will invoke getters and setters. Therefore it assigns properties versus just copying or defining new properties. Note that this should not be used for merging new properties into a prototype if the merge sources contain getters and you do not want [[Get]]
to be used on the getters. For copying property definitions and their enumerability into prototypes Object.getOwnPropertyDescriptor()
and Object.defineProperty()
should be used instead.const assign = require('assign-deep');
const config = {
admin: true,
author: {
name: { first: 'Joe' }
}
};
const locals = {
admin: false,
author: {
name: { last: 'Smith' },
username: 'joesmith'
}
};
console.log(assign(config, locals));
// {
// admin: false,
// author: {
// name: { first: 'Joe', last: 'Smith' },
// username: 'joesmith'
// }
// }
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Running and reviewing unit tests is a great way to get familiarized with a library and its API. You can install dependencies and run tests with the following command:
$ npm install && npm test
(This project's readme.md is generated by verb, please don't edit the readme directly. Any changes to the readme must be made in the .verb.md readme template.)
To generate the readme, run the following command:
$ npm install -g verbose/verb#dev verb-generate-readme && verb
You might also be interested in these projects:
Commits | Contributor |
---|---|
31 | jonschlinkert |
14 | doowb |
Jon Schlinkert
Copyright © 2019, Jon Schlinkert. Released under the MIT License.
This file was generated by verb-generate-readme, v0.8.0, on June 19, 2019.
FAQs
Deeply assign the values of all enumerable-own-properties and symbols from one or more source objects to a target object. Returns the target object.
The npm package assign-deep receives a total of 35,189 weekly downloads. As such, assign-deep popularity was classified as popular.
We found that assign-deep demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncover a malicious npm package posing as a tool for detecting vulnerabilities in Etherium smart contracts.
Security News
Research
A supply chain attack on Rspack's npm packages injected cryptomining malware, potentially impacting thousands of developers.
Research
Security News
Socket researchers discovered a malware campaign on npm delivering the Skuld infostealer via typosquatted packages, exposing sensitive data.